// 入口函数
$(function () {
    //需求1：点击a链接，显示隐藏
    $('#loginBox a').on('click', function () {
        $('#regBox').show()
        $('#loginBox').hide()
    })
    $('#regBox a').on('click', function () {
        $('#loginBox').show()
        $('#regBox').hide()
    })

    //需求2：定义校验
    let form = layui.form
    //定义校验规则：form.verify()
    form.verify({
        //参数是对象，属性是效验名称，值是规则
        username: [
            /^[\S]{1,10}$/,
            '用户名必须1到10位数字和字母'
        ],
        pwd: [
            /^[\S]{6,15}$/,
            '密码必须是6到15位数字和字母'
        ],
        //确认密码规则
        rePwd: function (value) {
            //value就是你给哪个标签添加这个效验规则
            let pwd = $('#regBox input[name=password]').val()
            if (pwd !== value) {
                return '两次密码输入不一致'
            }
        }
    })

    let layer = layui.layer
    //需求3：注册功能
    $('#formReg').on('submit', function (e) {
        e.preventDefault()
        //发送ajax
        axios({
            method: 'post',
            url: '/api/reguser',
            //不要传递对象类型，因为对象类型头信息设置的是application/json
            data: $(this).serialize()
        }).then(res => {
            ///判断返回数据是否正确
            if (res.data.status != 0) {
                return layer.msg(res.data.message)
            }
            //成功
            layer.msg('恭喜您，注册用户成功！')
            //切入到登录模块
            $('#regBox a').click()
            //清空表单
            $('#formReg')[0].reset()
        })
    })

    //需求4：登录功能
    $('#formLogin').on('submit', function (e) {
        e.preventDefault()
        //发送ajax
        axios({
            method: 'post',
            url: '/api/login',
            //不要传递对象类型，因为对象类型头信息设置的是application/json
            data: $(this).serialize()
        }).then(res => {
            ///判断返回数据是否正确
            if (res.data.status != 0) {
                return layer.msg(res.data.message)
            }
            //成功
            layer.msg('恭喜您，登录成功！')
            localStorage.setItem('token', res.data.token)
            //页面跳转index.html
            location.href = '/index.html'
        })
    })
})